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COPYRIGHT NOTICE 

A portion of the disclosure of this patent 
document contains material which is subject to 

10 copyright protection. The copyright owner has no 

objection to the facsimile reproduction by anyone of 
the patent document or the patent disclosure, as it 
appears in the Patent and Trademark Office patent 
file or records, but otherwise reserves all 

15 copyright rights whatsoever. 

BACKGROUND OF THE INVENTION 

The present application is related to U.S. Patent 

Application Serial No. , entitled "METHOD AND 

APPARATUS FOR RANDOM EARLY DETECTION OF DATA PACKETS OF 

20 NETWORK CONNECTIONS" , attorney docket number 23397.03100, 
filed October 18, 2001; and is also related to U.S. Patent 

Application Serial No. , entitled "METHOD AND 

APPARATUS FOR DISCARDING A PRIORITIZED FAIR SHARE OF TRAFFIC 
OF NETWORK CONNECTIONS", attorney docket number 23397.03000, 

25 filed October 18, 2001; and is also related to U.S. Patent 

Application Serial No. , entitled "METHOD AND 

APPARATUS FOR CACHING FREE MEMORY CELL POINTERS", attorney 
docket number 23397.03400, filed October 18, 2001; the 
disclosures of which are herein incorporated by reference. 



1 



Attorney Docket No. 10327- 003600US 



PA 3240608 vl 




Field of the Invention 

The present invention generally relates to quality of 
service of computer networks, such as the Internet. The 
present invention more particularly relates. to managing the 
5 bandwidth available amongst a set of network connections of a 
computer network. 

Discussion of Background 

It is hard to dismiss the entrepreneurial nature of the 
Internet; this is no longer a research project. For most 

10 organizations connected to the global Internet, the Internet 
is a full-fledged business interest. Having said that, it is 
equally hard to dismiss. the poor service quality that is 
frequently experienced. The rapid growth of the Internet, and 
increasing levels of traffic, make it difficult for Internet 

15 users to enjoy consistent and predictable end-to-end levels of 
service quality. 

The Internet has historically offered a single level of 
service, that of "best effort, " where all data packets are 
treated with equity in the. network. However, we are finding 

20 that the Internet itself does not offer a single level of 

service quality, and some areas of the network exhibit high 
levels of congestion and consequently poor quality, while 
other areas display consistent levels of high quality service. 
Customers are now voicing a requirement to define a consistent 

25 service quality they wish to be provided, and network service 
providers are seeking ways in which to implement such a 
requirement. This effort is happening within the umbrella 
called "Quality of Service" (QoS) . Examples of factors that 
affect QoS on the Internet include delay, bandwidth, and 

30 reliability. 
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Delay is the elapsed time for a packet to be passed from 
the sender, through the network, to the receiver. The higher 
the delay, the greater the stress that is placed on the 
transport protocol to operate efficiently. For Transfer 
■5 Control Protocol (TCP) , higher levels of delay imply greater 
amounts of data held "in transit" in the network, which in 
turn places stress on the counters and timers associated with 
the protocol. It should also be noted that TCP is a 
"self clocking" protocol, where the sender's transmission rate 

10 is dynamically adjusted to the flow of signal information 
coming back from the receiver, via the reverse direction 
acknowledgments (ACK's), which notify the sender of successful 
reception. The greater the delay between sender and receiver, 
the more insensitive the feedback loop becomes, and therefore 

15 the protocol becomes more insensitive to short term dynamic 
changes in network load. For interactive voice and video 
applications, the introduction of delay causes the system to 
appear unresponsive. 

Bandwidth is the maximal data transfer rate that can be 
20 sustained between two end points. It should be noted that 

this is limited not only by the physical infrastructure of the 
traffic path within the transit networks, which provides an 
upper bound to available bandwidth, but is also limited by the 
number of other flows which share common components of this 
25 selected end-to-end path. 

Reliability is commonly considered a property of the 
transmission system, and in this context, it can be thought of 
as the average error rate of the medium. Reliability can also 
be a byproduct of the switching system. A poorly configured 
30 or poorly performing switching system can alter the order of 
packets in transit, delivering packets to the receiver in a 
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different order than that of the original transmission by the 
sender, or even dropping packets through transient routing 
loops . 

The Internet is composed of a collection of routers and 
5 transmission links. Routers receive an incoming packet, 

determine the next hop interface, and place the packet on the 
output queue for the selected interface. Transmission links 
have characteristics of delay, bandwidth and reliability. 
Poor. service quality is typically encountered when the level 

10 of traffic selecting a particular hop exceeds the transmission 
bandwidth of the hop. for an extended period time. In such 
cases, the router's output queues associated with the 
saturated transmission hop begin to fill, causing additional 
transit delay, until the point is reached where the queue is 

15 filled, and the router is then forced to discard packets or at 
least portions of packets (reduced reliability) . This in turn 
forces adaptive flows to reduce their sending rate to minimize 
congestion loss, reducing the available bandwidth for the 
application. 

20 Unfortunately, present methods of managing bandwidth, 

delay, and reliability have been inadequate, given the 
increasingly demanding transmission needs of users of the 
Internet . 
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SUMMARY OF THE INVENTION 

It has been recognized that what is needed is an 
inexpensive, efficient technique for improving bandwidth, 
delay, and reliability of a network connection. Broadly 
5 speaking, the present invention fills these needs by providing 
a method and an apparatus for inserting empty memory cells 
into a data flow of network connections of a computer network. 
It should be appreciated that the present invention can be 
implemented in numerous ways, including as a process, an 
10 apparatus, a system, a device or a method. Several inventive 
embodiments of the present invention are described below. 

In one embodiment, a method is provided for inserting' 
empty memory cells into a data flow of network connections of 
a computer network. The method comprises the following: 
15 receiving an insertion request for an empty memory cell to be 
inserted into the data flow; receiving a base connection 
identification (CID) associated with the insertion request; 
determining an appropriate insertion scheme for carrying out 
the insertion request; and based on the appropriate insertion 
20 scheme, sending the insertion request to an insertion device 

configured to insert the empty memory cell into the data flow. 

In another embodiment, an integrated circuit is provided 
that is configured to insert empty memory cells into a data 
flow of, network connections of a computer network. The 
25 integrated circuit comprises controller circuitry configured 

to control operations of the following: receiving an insertion 
request for an empty memory cell to be inserted into the data 
flow; receiving a base connection identification (CID) 
associated with the insertion request; determining an 
30 appropriate insertion scheme for carrying out the insertion 
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request; and based on the appropriate insertion scheme, 
sending the insertion request to an insertion device 
configured to insert the empty memory cell into the data flow. 

Advantageously, the present invention demonstrates, that 
5 high quality of service (QoS) is possible in the Internet, 
even with increasingly demanding transmission requirements. 
The present invention makes it possible to deliver best effort 
traffic in a manner which is predictable and fairly 
consistent. For example, the present invention deals with 
10 problems that may arise when it is necessary to insert data 
into an incessant stream of data flow. 

The invention encompasses other embodiments of a method, 
an apparatus, and a computer- readable medium, which are 
configured as. set forth above and with other features and 
15 alternatives. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention will be readily understood by the 
following detailed description in conjunction with the 
accompanying drawings . . To facilitate this description, like 
5 reference numerals designate like structural elements. 

FIG. 1 shows the environment in which the Forte subsystem 
ASIC operates, in accordance with one embodiment of the 
present invent ion . 

FIG. 2 is a high-level view of the FSS, in accordance 
10 with one embodiment of the present invention. 

FIG. 3 is a high-level view of the environment of the 
Forte ASIC, in accordance with one embodiment of the present 
invention. 

FIG. 4 shows the functional architecture for the Forte 
15 ASIC, in accordance with one embodiment of the present 
invention. 

FIG. 5 shows the functional architecture of the Forte 
ASIC surrounding the cell insertion block, in accordance with 
one embodiment of the present invention. 

20 FIG. 6 shows the functional architecture of the Forte 

ASIC surrounding the OAM Bypass block 418, in accordance with 
one embodiment of the present invention. 

FIG. 7 shows the functional architecture of the Forte 
ASIC surrounding the OAM Scan block, in accordance with one 
25 embodiment of the present invention. 

FIG. 8 shows the functional architecture of the Forte 
ASIC surrounding the Performance Monitoring block, in 
accordance with one embodiment of the present invention. 
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FIG. 9 shows the functional architecture of the Forte 
ASIC surrounding the CPU Controller block, in accordance with 
one embodiment of the present invention. 

FIG. 10 shows the functional architecture of the Forte 
5 ASIC surrounding the Back Pressure Controller block, in 
accordance with one embodiment of the present invention. 

FIG. 11 shows the functional architecture of the Forte 
ASIC surrounding the SIFwire Controller, in accordance with 
one embodiment of the present invention. 
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DESCRIPTION OF THE PREFERRED EMBODIMENTS 

An invention is disclosed for a method and an apparatus 
for inserting empty memory cells into a data flow of network 
connections of a computer network. Numerous specific details 
5 are set forth in order to provide a thorough understanding of 
the present invention. It will be understood, however, to one 
skilled in the art, that the present invention may be 
practiced without some or all of these specific details. 

The list below provides a quick reference to acronyms 
10 used in this disclosure. 

AAL5 - ATM Adaptation Layer Type 5 - single bit field in CD 
which indicates that cells on a connection constitute 
CPAAL5_PDU packets. 

ABR - Available Bit Rate - QoS traffic class defined by the 
15 ATM Forum. 

ABRC - ABR Controller inside the Forte. 

ABR DC - ABR daught ercard . 

ABRQCount - Count of the number of cells which have passed on 
the ABR QueuelD since the most recent ABRQFill report to 
20 the ABR daughtercard. 

ABRQFill - Count of the number of cells in the cell buffer on 
the ABR QueuelD.. 

AIS - Alarm Indication Status 

AvgOccCIDs - Average of NumOccCIDs . 
25 BPC - Back Pressure Controller. 

BERT - Built-in External Ram Test. 

BRC - Backward Reporting Cell. 

b-RM - backwards RM cell for ABR connections. 



Attorney Docket No. 10327 - 003 600US 



9 



PA 3240608 vl 



CAC - Connection Admission Control - Network Management system 
level process which controls usage of bandwidth by 
connections. 

CB - Circular Buffer. 
5 CBR - Continuous Bit Rate. 

CCP - Cell Control Path. 

CCR - ABR Current Cell Rate. 

CD - CellDescriptor - the collection of fields used by the 

Cell Control Path to identify one cell. 
10 CDByp - CD which traverses the FSS Bypass block to bypass the 

remainder of the Cell Control Path. 
CDDisc - CD processed by Discard block. 

CDexEB - CD received by FSS from Egress Backplane Interface 
Subsystem. 

15 CDexQSS - CD received by FSS from QSS . . 
CDP - Cell Data Path. 

CDtoEB - CD from FSS to Egress Processor subsystem . 
CDtoQSS - CD from FSS to QSS. 

CellPtr - Cell pointer - address of cell in the Cell Buffer. 
20 CID - ConnectionID - the 16 bit identifier which binds a cell 

to a connection between an incoming VPI/VCI and an 

outgoing VPI/VCI. 
CIDCount - per-CID cell buffer occupancy. 

CLP - Cell Loss Priority - ATM Cell Header field in which cell 
25 is x tagged' . 

CPU - Central Processing Unit - Management Processor which 
monitors and controls the SIF board and provides the 
interface to the network management . 
CRC - Cyclic Redundancy Check. 
30 DR - Discard (external) RAM. 

EBISS - Egress Backplane Interface Subsystem. 
EOC - Egress Output Controller. 
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EOF - End of Frame - flag which indicates the end of a 
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CPAALS__PDU (packet). 
EPSS - Egress Processor Subsystem. 
ER - ABR Explicit Rate. 

f-RM - Forward RM cell of ABR connections. 



FMC 



Forward Monitoring Cell. 



FSS 



Filter Subsystem. 



HEC 



Header Error Check. 



ICI 



Ingress Connection Identifier. 



10 Int - Interrupt . 

IPSS - Ingress Processor Subsystem. 
ITSS - Ingress Timing Subsystem. 

LIM - Line Interface Module - physical layer transceiver card. 
MCR - ABR Minimum Cell Rate. 
15 MR - Multicast (external) RAM. 

MTS - Main Timing Sequence - fixed length sequence of ASIC 
clock cycles. 

Nrm - Number of RM cells - ATM Forum defined integer which 



20 NRT - Non Real Time - traffic class which is not sensitive to 
. cell delay or cell delay variation. 
0AM- Operations Administration and Maintenance (cell). 
PID - Port Identifier - 5 bit CD field which identifies 



25 PMG - Performance Monitoring Group. 
PMID - PMG Identifier. 
Port ID - Egress port ID. 
PR - Pointer (external) RAM. 

PTI - Payload Type Identifier - ATM Cell Header field. 
30 QueuelD - Queue Identifier - 4 bit field priority field (0 is 
highest) . 

QID - QueuelD - 4 bit field priority field (0 is highest). 



defines the cell spacing between RM cells. 



destination ALM output port. 
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QoS - Quality of Service. 
QSS - Queue Subsystem. 

RdPtr - Read Pointer which obtains information from head of 

free list or circular buffer. 
5 rm - Resource Management cell in which ABR flow control 

information is carried. 
RMdir - RM Cell Direction bit - single bit field in CD which 

indicates whether RM cell is forward or backward. 
rt-VBR - real time VBR. 
10 SAR - Segmentation and Reassembly cell to CPU. 
SIF - Switching Interface. 
SIFT - 622 Mbps switch interface card 
SIF2 - 2.4 Gbps switch interface card 
SSS - Scheduling Subsystem. 
15 Th - Threshold. 

UTOPIA - Universal Test & Operations PHY Interface for ATM. 
VBR - Variable Bit Rate. 

VCI - Virtual Channel Identifier - ATM Cell Header field. 
VD - Virtual Destination for ABR connections. 
20 VDfRM - ABR Virtual Destination forward RM cell. 

VPI - Virtual Path Identifier - ATM Cell Header field. 
VS - Virtual Source for ABR connections. 

VSCount - number of cells since most recent VS f -RM cell. 
VSfltM - ABR Virtual Source forward RM cell. 
25 WrPtr - Write Pointer which appends information to a linked 
list or circular buffer. 

. General Overview 

FIG. 1 shows the environment in which the Forte subsystem 
ASIC 104 operates, in accordance with one embodiment of the 
30 present invention. The Forte ASIC 104 includes controller 

circuitry configured to control operations of the insertion of 
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memory cells. The Forte ASIC 104 is in electrical 
communication with a Filter subsystem ASIC (FSS) 102 a Queue 
subsystem ASIC (QSS) 110, a Schedule subsystem ASIC (SSS) 108, 
and an egress backplane interface subsystem (EBISS) ASIC 112. 
5 These subsystems are further discussed below with reference to 
FIG. 2 through FIG. 11. The given names (e.g., "Filter," 
"Forte," "Schedule," "EBISS " "Bertie "and "Queue") are for 
identification purposes only. The embodiment is not limited 
to these names. 

10 High-Level Description of the Filter Subsystem ASIC (FSS) 

The Filter Subsystem (FSS) 102 manages the Cell Buffer, 
performs multicasting, generates empty cell timeslots for 
Operations Administration and Maintenance (0AM) cells and 
Available Bit Rate (ABR) Virtual Source (VS) forward resource 
15 management (f-RM) cells, and supports ABR explicit rate (ER) 
functions. 

FIG. 2 is a" high-level view of the FSS 102, in accordance 
with one embodiment of the present invention. User Data 
traffic flows from the Egress Backplane Interface Subsystem 
20 (EBISS) 112 through the Discard block 210 to the remainder of 
the Cell Control Path (Queue and Schedule Subsystems 110) and 
again through the FSS 102 to the EBISS 112. 

Some of that traffic is removed from the stream in the 
Discard block 210. Traffic from the ABR Virtual Destination 

25 (VD) forward Resource Management (f-RM) stream and from the 

segmentation and reassembly (SAR) stream bypass the. remainder 
of the Cell Control Path via the Bypass block 208. ABR and 
0AM cells generated by the Cell Slot Generator 206 flow 
through the remainder of the Cell Control Path, again through 

30 the FSS to the Egress Processor. 
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The free list block 214 manages cell pointers, which 
point to cell storage locations within the Cell Buffer. The 
multicast block 216 generates copies of cells by generating 
multiple cell descriptors (CDs) whose dummy cell pointers 
5 point to the original cell pointer and cell in the Cell 
Buffer. 

The Discard block 210 manages usage of the Cell Buffer by 
selectively discarding cells as they arrive . The Discard 
block 210 also supports some ABR VS/VD and ER functions. 

10 The cell, slot generator 206 generates and inserts cell 

placeholders into which cells may be inserted by the Egress 
Processor Subsystem (EPSS) . ABR Virtual Source (VS)f-RM slots 
are inserted at regular cell spacings into ABR VS connections 
to support ABR flow control. Each placeholder allows the ABR 

15 daughter card to insert one VS f-RM cell. The placeholder CD 
is inserted into the stream of user data CDs and traverses the 
Cell Control Path, and may be shaped prior to being passed to 
the EBISS 112. The Cell Slot Generator block maintains a cell 
counter for each ABR VS connection. The counter and the 

20 configurable cell spacing parameters for each ABR CID are 

stored in Discard RAM. The Cell Slot Generator also inserts 
OAM and other cells at the request of the EPSS via switch 
interface wire (SIFwire) . 

The Bypass block 208 provides two channels which bypass 

25 the remainder of the Cell Control Path. One channel is 

provided for SAR cells whose destination is the local CPU; the 
other is for ABR VD f-RM cells (not to be confused with VS f- 
RM cells) which are received from an upstream virtual source. 
Neither of those streams requires shaping. 
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The Remapping block 212 remaps MC dummy cell pointers to 
original cell pointers, returns cell pointers to the free list 
circular buffers, and maintains cell counters used by the 
Discard block 210. 

5 Hiah-Level Description of the Forte Subsystem ASIC 

FIG. 3 is a high-level view of the environment of the 
Forte ASIC 104, in accordance with one embodiment of the 
present invention. The Presto ASIC 304 and Tempo ASIC 306 
perform Ingress path processing. The Forte ASIC 104 performs 

10 Egress path processing. The Egress. Backplane Interface 

Subsystem (EBISS) is shown in FIG. 1 and FIG. 2, respectively. 
The given names (e.g., "Presto," "Tempo," "Forte," "Bertie," 
and "Filter") are for identification purposes only. The 
embodiment is not limited to these names. FIG. 3 illustrates 

15 the relationships between Presto 304, Tempo 306, and Forte 
104. Also shown is the relationships these ASICs have with 
the backplane and with associated Line Interface Modules 
(LIMs) 312 and 322 for two SIF2 boards in a common chassis. 
Cell data flows are indicated by arrows. 

20 On egress, cell data arid new cell descriptors come in 

from the BERTIEs 308. The cells are then transformed into a 
format suitable for transmission to the LIM interface 312 or 
SAR subsystem 316 before being transmitted to the LIM 312 or 
S AR 316. 

25 Cells may be transmitted at a maximum rate of 2.4 Gbps. 

The 2.4 Gbps cell stream may consist of one single SONET 0C- 
48c (concatenated) stream, four independent SONET OC-12 
streams forming one SONET OC-48 port, or any combination of 
SONET OC-12 and lower rate streams. A maximum of 16 LIM ports 

30 may be configured. 
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FIG. 4 shows the functional architecture for the Forte 
ASIC 104, in accordance with one embodiment of the present 
invention. The functions that the Forte 104 performs, are 
grouped into the illustrated blocks (blocks 404 to 430) , which 
5 are further discussed below with reference to FIG. 5, FIG. 6, 
FIG. 7, FIG. 8, FIG. 9, FIG. 10, and FIG. 11. The related 
external interfaces are shown. Cell paths are shown with bold 
lines. Control signals and data with light lines. 

Cell Insertion 

10 FIG. 5 shows the functional architecture of the Forte 

ASIC 104 surrounding the cell insertion block 402 , in 
accordance with one embodiment of the present invention. The 
Cell Insertion block 402 is responsible for requesting empty 
cell slots in the data flow from the Filter Subsystem 102. 

15 These requests can come from several sources, including the 
Performance Monitoring block 426, OAM Bypass 418, ABR 
daughtercard (ABR DC) 318, CPU 404, and the OAM Scan 430. 

Insertion requests to the FSS 102 are preferably made in 
the following priority order: 
20 1. OAM Bypass block 418 (BRC and Backward Loopback OAM 

Insertion) , 

2. Performance Monitoring block 426 (FMC OAM 
Insertion) , 

3. ABR DC 420 (VS f-RM Cell Insertion) , 
25 4. CPU 404 (Cell Insertion), 

5. OAM Scan 430 (AIS, RDI and CC Cell Insertion) . 

Each block will present the CID of their next cell 
insertion request, if they have one, to the Cell Insertion 
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block 402. The Cell Insertion block 402 will take the request 
from the highest priority block (i.e., the OAM Bypass block 
418) and perform a CID lookup in the Scan List 430 to obtain 
the information required to initiate an insertion request to 
the FSS 102. The information returned from the Scan List 
lookup 430 is shown below in below in Table 1. 



type Scanlnfo is 




record 




QID[3:0]; 


QID - required by QSS 


PID[3:0]; 


PID - used to determine unshaped CID 


CPU Shaped; 


CPU uses shaped CID 


Bypass-Shaped; 


OAM Bypass uses shaped CID 


end record; 





Table 1. Example of Pseudo-Code of Information returned from 

the OAM Scan 43 0 . 



The Cell Insertion block then builds a SIFwire 
instruction using the Insertion request source and the 
Scanlnfo. Table 2 below shows the different types of cells 
that can be requested. 



Cell Type Code 


Description 


Notes 


0000-0001 




reserved 


0010 


CPU 


Cell Inserted by CPU 


0011 


OAM Bypass 


Cell Inserted by OAM Bypass 


0100 


ABR DC VS f-RM 


ABR f-RM Cell Inserted by 
ABR DC 


0101-0111 


reserved 




1000 


AIS Segment 


OAM Cell Inserted by Scan 


1001 


AIS End-to-end 


OAM Cell Inserted by Scan 


1010 


RDI Segment 


OAM Cell Inserted by Scan 


1011 


RDI End-to-end 


OAM Cell Inserted by Scan 
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1100 


CC Segment 


OAM Cell Inserted by Scan 


1100 


CC End-to-end 


OAM Cell Inserted by Scan 


1110 


FMC 


OAM Cell Inserted by OAM 
Processor 


1111 


reserved 





Table 2. Example the different types of cells that can be 
requested from the Cell Insertion block 402. 



There are two schemes used for insertion requesting, both 
involve sending a SIFwire. command to the FSS 102 and 
5 requesting a slot. The SIFwire command contains the 
information shown below in Table 3. 



type FSS-Insertion_Data is 




record 




CellType[3:0];-- 


Used to tell the Forte how to fill the cell 


CID[15:0]; - 


CID used for the inserted cell 


QID[3:0]; 


QID used by the QSS 


end record; 





Table 3 . Example of Pseudo-Code of Information Contained in a 

SIFwire command. 



The first scheme involves requesting the slot using the 
10 actual connection's CID. This ensures that the slots are 

shaped according to the connection's shaping parameters in the 
SSS 108. 

The second scheme involves requesting the slots using 16 
dedicated unshaped CIDs (one per port), that are not shaped. 
15 This requesting technique has the advantage that the cell 

slots travel through the Cell Control Path relatively quickly. 
The slots are not shaped according to the actual connections 



Attorney Docket No. 10327- 003600US 



18 



PA 3240608 vl 



A flC^iiB-lB GTSiS .1. BE! 

shaping parameters in the SSS 108. The CPU must configure the 
16 connections in the system, and configure the base CID for 
the 16. connections, and which QID to use for the insertion 
request . 

5 Most cell insertion requests are sent to the FSS 102 

using the first scheme, so that the cells are inserted and 
shaped according to the connections parameters in the SSS 108. 

ABR DC VS f-RM cell insertion requests are sent to the 
FSS 102 using scheme 2. The reason for using the second 
10 scheme is that it is possible for the ABR rate to have been 
reduced to 0. As a result, any cell inserted on the actual 
connection would never make it out of the SIF. So, there 
would be no way to increase the rate. 

OAM Bypass 418 and CPU cell slot insertion requests can 
15 use either method. The "unshaped" flags in the Scan List 420 
indicate which scheme to use. 

ABR DC VS f-RM, OAM Bypass 418 and CPU cell insertions 
also have a timeout mechanism to prevent head of line blocking 
if the cell slot takes too long to get back to the Forte 104. 
20 The timeout counters are programmable 16 bit down counters. 
They start counting down when the cell insertion is sent to 
the FSS 102, when they reach zero the cell is discarded and 
the CPU is informed. 

Each MTS, the Cell Insertion block .402 will send a 
25 request if it has one pending. The FSS 102 can always insert 
one insertion request every MTS. So, no feedback is required 
to indicate that the insertion was processed. 
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RequestNextInsertion() 


NoRequest <= FALSE; 


If 


(OAM BypassRequest - TRUE) then « BRC or Backward LB OAM 




Req.CellType <= OAM_Bypass; 




if (OAMBypass Unshaped = FALSE) then 




Req.QID <= OAM-Bypass 


Request.QID; 






Req.CID <= OAM- 


BypassRequest.CID; 




else 




.Keq.v^iiJ < -— unsnapea.i^/iL/, 




Req.CID <= UnshapedBase + ScanList.PID; 




end if; 


elsif 


(Perfmon Request = TRUE) then -- FMC Insertion 




Req.CellType <= FMC (SEG or E2E); 




Req.QID <= PerfMon Request.QID; - from ScanList 




Req.CID <= PerfMon Request.CID; 


Elsif 


(ABRDC Request = TRUE) then - VS f-RM cells 




Req.CellType <= FSS_ABR VS -fRM; 




Req.QID <= Unshaped.QID; 




Req.CID <= Unshaped.CID + ScanList.PID; 


elsif 


(CPU Request = TRUE) then -- Any type of cell 




Req.CellType <= CPU; 




if (CPU Unshaped - FALSE) 


then 






Req.QID <= 


CPU_Request.QID; 




Req.CID <= 


CPURequest.CID; 




else 




Req.QID <= Unshaped.QID; 




Req.CID <= UnshapedBase + 


ScanList.PID; 




end if; 


elsif 


(Scan Request = TRUE) then-- AIS, RDI, CC OAM Cells 
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Req.CellType <= AIS, RDI or CC; 
Req.QID <= Scan Request.QID; 
Req.CID <= Scan Request.CID; 

else 

NoRequest <= TRUE; 

end if; 

if (NoRequest - FALSE) then 

SendSIFwiretoFSS(Req); 

end if; 

end RequestNextlnsertion: _ 

Table 4. Example Pseudo-Code of a Cell Insertion Request from 

the Cell Insertion block 402. 

QAM Bypass 

FIG. 6 shows the functional architecture of the Forte 
5 ASIC 104 surrounding the OAM Bypass block 418, in accordance 
with one embodiment of the present invention. The OAM Bypass 
is described in relation to the insertion of looped back OAM 
cells from the Presto ASIC 304. 

The OAM Bypass block 418 can receive one cell at a time, 
10 from the Presto 304, to be inserted in the Egress cell flow. 
The cell is sent to the Forte 104 across a 5 pin interface (4 
data pins and one parity pin) . The information received from 
the Presto is shown in Table 5 below. 
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type Presto DATA is 
record 

ICI[15:0]; 

CellHeader array (1 to 4) of [7:01 ; 
CellPayload array (1 to 48) of [7:0]; 
end record: 

Table 5. Example Pseudo-Gode of Information Received by the 
Forte ASIC 104 from the Presto ASIC 304 

The ICI (Ingress Connection Identifier) is used to 
perform an ICI to CID lookup. Once the CID is known, the CID 
5 is presented to the Cell Insertion block 402. The Cell 

Insertion block 402 performs a lookup in the Scan Table in the 
0AM Scan block 430 to find out which insertion scheme to use 
for the insertion request and then issues the request to the 
FSS 102. 

10 The OAM Bypass block 418 applies back pressure to the 

Presto 304 until the cell has been transmitted. This is 
because the Forte 104 can hold only one cell at a time. 

When the cell is finally transmitted, the back pressure 
to the Presto 304 will be removed so that another cell can be 
15 looped back. 

Note that it is the responsibility of the Presto 304 to 
format the cell correctly. The Forte 104 will perform VPI/VCI 
mapping and destination port lookup for all cells received via 
the bypass interface, but it will not modify any other part of 
20 the payload. 

At the time the initial request is sent to the FSS 102, 
the OAM Timeout counter starts to decrement once per MTS . If 
the counter reaches zero, an OAM Timeout Interrupt will be 
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sent to the CPU. This basically means that the insertion 
request has been lost. However, it is possible that the 
initial insertion request has just been seriously delayed and 
may eventually arrive at the Forte 104. The Forte 104 will 
5 discard any cells that are tagged with a CellType of OAMBypass 
if they do not match the appropriate CID. 

The OAM Timeout initial value can be configured by the 
CPU. If this initial value, is set to zero, then the timer 
will be disabled. 

10 When an OAM timeout occurs, the cell in the Forte 104 

will be discarded, and the request line to the Presto 304 will 
be asserted in order to get another cell . 

QAM Scan 

FIG. 7 shows the functional architecture of the Forte 
15 ASIC 104 surrounding the OAM Scan block 430, in accordance 
with one embodiment of the present invention. A set of OAM 
flags is maintained for each CID in a CID Scan lookup table 
held in the Statistics RAM. For each connection, a flag 
indicates which type of OAM cells should be inserted during 
20 "Scan". Table 6 below indicates the flags maintained per CID, 
and the type of cell generated. 
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Finer 
r lag 


Description 


GenAISseg 


Generate segment AIS 


GenAISe2e 


Generate end-to-end AIS 


GenRDIseg 


Generate segment RDI 


GenRDIe2e 


Generate end-to-end RDI 


GenCCseg 


Generate segment CC 


GenCCe2e 


Generate end-to-end CC 



Table 6. Examples of Flags Maintained Per Connection 

Identification (CID) . 



The CPU initiates the scan by writing to the Forte 104. 
The Forte 104 scans the entire CID Scan table starting from 
5 CID 0/ examining the set of OAM flags at each entry. Each set 
flag will cause the Forte 104 to request the FSS 102 to insert 
an OAM cell slot into the egress flow through the Cell Control 
Path using the first insertion scheme (always shaped to the 
actual CIDs shaping parameters) . The OAM Scan block 430 
10 presents the CID and CellType to the Cell Insertion block 402, 
which will issue the insertion request to the FSS 102 when 
there are no other insertion requests pending from any other 
block. The Scan List insertions have the lowest priority. 

When the request has been processed by the Cell Insertion 
15 402, the OAM Scan block 430 will move on to the next flag, so 
that the next request can be made. This step will continue 
until the entire scan list has been cycled through, at which 
point the CPU will be informed via an interrupt. 

Note that no attempt is made to insert these OAM cells in 
20 a priority order based on QID. The reason is because there is 
no stringent timing requirement for these cell insertions 
other than that they are generated approximately once per 
second . 
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Performance Monitoring 

FIG. 8 shows the functional architecture of the Forte 
ASIC 104 surrounding the Performance Monitoring block 426, in 
accordance with one embodiment of the present invention. The 
5 Performance Monitoring block 426 in the Forte is responsible 
for requesting insertion of Forward Monitoring Cells (FMC) and 
maintaining fields for use in Performance Monitoring. This 
monitoring involves requesting insertion of Forward Monitoring 
Cell (FMC) slots from the FSS 102. 

10 The Forte 104 can maintain Performance Monitoring (PM) on 

up to 511 Performance Monitoring Groups (PMG) . Each PMG can 
consist of one or more connections. A connection is assigned 
to a PMG by the CPU writing the PMID into the CID lookup 
table, so that when the CID lookup is performed, the PMG can 

15 be determined. 

Performance Monitoring on a particular group is initiated 

by the Forte 104 on command from the CPU. The CPU indicates 

the block size that will be used for the PMG.' The block size 

is preferably 128, 256, 512 or 1024 cells. 
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function StartPMG() 

PMGT(WhichPMG).Enabled <= TRUE; 
PMGT(WhichPMG).First <= TRUE; 
SendFMCRequest(PMGT(WhichPMG).CID); 
PMGT(WhichPMG).BlockCount <= 0; 



set the Group enable bit 
Ready for the first FMC 
SIFwire request to FSS 
Zero all of the counts 



PMGT(WhichPMG).B lockReqCount <= 0; 
PMGT(WhichPMG).MCSN <= 0; 
PMGT(WhichPMG).TUC <= 0; 
PMGT(WhichPMG).TUCO <= 0; 
PMGT(WhichPMG).BEDC <= 0; 
e nd StartPMG; 

Table 7. Example Pseudo-Code of Command to Start Performance 



To initiate performance monitoring, the Forte 104 sends a 
command to the FSS 102 requesting the insertion of an OAM FMC 
5 on a particular CID. The FSS 102 will then insert an OAM FMC 
Cell Descriptor into the cell flow within one MTS . 

When the inserted OAM FMC cell reaches the Forte 104, the 
Forte 104 will be aware that the OAM FMC cell is in fact the 
first FMC in the PMG . The Forte 104 will initialize all of 
10 the appropriate fields associated with the PMG and will insert 
them into the OAM FMC, so that it will be ready for 
transmission. Table 8 below shows shows the fields configured 
by .the CPU for Performance Monitoring. 



Monitoring 
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Field Name 


Meaning 


Enable 


Start performance monitoring 


BIockSize[l:0] 


Number of cells between FMC (128, 256, 512 or 
1024) 


F4_Level 


Level of the block test (ie F4 for VPCs or F5 for 
VCCs) 


Seg_E2E 


Segment or End-to-end connection 


CID[15:0] 


CID to use for requested FMCs 



Table 8. Examples of OAM Forward Monitoring Fields Configured 

by the CPU 



Table 9 below shows the fields configured and maintained 
5 by the OAM Processor. 



Field Name 


Meaning 


Set by 


First 


First FMC through on 
PMG 


Set when CPU sets Enabled, and 
cleared on first FMC. 


BlockCount[15:0] 


Number of cells since 
last FMC 


set to 0 on every FMC, Inc after 
every "User Cell" in group. 


BlockReq Count[15:0] 


Number of cells since 
last request 


set to 0 on First FMC, Inc after 
every "User Cell" in group, 
Cleared when count equals Block- 
Size 


MCSN[7:0] 


Monitoring Cell 
Sequence Number 


set to 0 on first FMC, Inc after 
every FMC in group. 


TUC[15:0] 


Total User Cell Count 
(CLP = 0 or 1) 


set to 0 on first FMC, Inc after 
every "User Cell" in group. 


TUC0[15:0] 


Total User Cell Count 
(CLP = 0) 


set to 0 on first FMC, Inc after 
every "User Cell" in group with 
CLP=0. 


BEDC[ 15:0] 


Block Error Detection 
Code (BIP-16) 


set to 0 on first FMC, modified 
during every "User Cell" 



Table 9. Examples of OAM Forward Monitoring Fields Configured 
10 by the OAM Processor 
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When the first FMC goes through, the MCSN, TUC, TUCO, BEDC , 
BlockCount and BlockReqCount will be set to 0, and the "First" 
flag will be cleared. 

function RxFMC() I 
if (CellType = FMC) then 

WhichPMG <= CID.PMG -- from Egress RAM 
if (PMGT(WhichPMG).Enabled = TRUE) then 
-- is this the first FMC in the group? 
If (PMGT(WhichPMG).First = TRUE) then 
PMGT(WhichPMG).First <= FALSE; 
else - not the first FMC 

- Check for early FMC. 

if (PMGT(WhichPMG).BlockCount < BlockSize/2) then 
GeneratePMGUnderflo wError() ; 
end if; 

PMGT(WhichPMG).MCSN <= MCSN +" 1; 

end if; 

FillFMC(WhichPMG); 
PMGT(WhichPMG).BEDC <= 0; 
PMGT(WhichPMG).BlockCount <= 0; 

end if; 

end if; 

end RxFMC; 

Table 10. Example Pseudo-Code for Function for Requesting 
5 Forward Monitoring Cells 

From then on, every "User Cell" associated with the PMG will 
cause the TUC, TUCOand BlockCount and BlockReqCount fields to 
be incremented, and the BEDC field to be updated. Once the 
BlockReqCount field has reached the BlockSize, another 
10 insertion request will be queued, and the BlockReqCount will 
be cleared. Up to four FMC insertion requests can be queued 
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in any one MTS . The queue is maintained in the Statistics RAM 
and can hold 512 entries. 

The worst case scenario, is for all 511 PMG to require 
requesting of FMC Insertions consecutively. This could happen 
5 over 128 MTSs. Every MTS the Forte can send a request to 
Filter, so it will only take 512 MTS (plus a few for OAM 
bypass insertions that are at a higher priority) to clear the 
back log. This should be sufficient as there has to be 128 
user data cells before another request can take place (32 
10 MTSs) and in that time 32 FMC requests should have been 
processed. 

The head and tail of the queue are kept inside the Forte 
104. The CID of the entry at the head of the queue is 
presented to the Cell Insertion block 402 until its request 
15 has been processed, then the next entry in the queue will be 
issued. 

When the FMC arrives at the Forte. 104, the TUC, TUCO and 
BEDC values will be written into it. The MCSN will be 
incremented and written into the cell, and the cell will then 
20 be ready for transmission. 



function Fi 11 FMC() 

Cel 1 .VPI <= CID.VPI;- from Egress RAM 

if (PMGT WhichPMG .F4 Level - TRUE) then - VP Connection 
if (PMGT(WhichPMG).Seg E2E ■= Seg) then 
Cell.VCl <-3; 

else 

Cell.VCI<=4;, 

end if; 

Cell.PTI<= 000b 
Cel 1 .CLP <= FSSData.CLP; 
else -- VC Connection 

Cell.VCl <= CID.VCI; - from Egress RAM 
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if (PMGT(WhichPMG).Seg E2E = Seg) then 
Cell.PTI<= 100b; • 

else 

Cell.PTI <= 101b 

end if; 

end if; 

Cell.OAM-Type <= 0010b; 

Cell.FnType <= 0000b; 

CelLMCSN <= PMGT(WhichPMG).MCSN; 

Cell.TUC <= PMGT(WhichPMG).TUC; 

Cel l.BEDC <= PMGT(WhichPMG).BEDC; 

Cell.TUCO <= PMGT(WhichPMG).TUCO; 

Cell.TSTP <= OxFFFF; 

Cell.Unused <= Filled with 0x6As. 

Cell.TRCCO <= 0x6A6A; 

Cell.BLER <= 0x6A. 

Cell.TRCC <= 0x6A6A; 

Cell.Res <= 000000b. 

end FillFMCQ ' 

Table 11. Example Pseudo-Code of Function for Filling a 

Forward Monitoring Cell 

If BlockCount is more then 1.5 times BlockSize or less then 
0.5 time BlockSize when the FMC arrives an error will be 
5 raised to the CPU. Note that the Block Count is cleared when 
the FMC arrives. This continues until the CPU informs the 
Forte 104 that it should stop performance monitoring on the 
PMG. 

To determine if a cell is a "User Cell," it is determined 
10 if the PMG is related to a F4 level connection. If so, then a 
"User Cell" is any cell that has a VCI that is 1, 2, 5 or VCI 
>= 16. If the PMG is related to F5 level connection then a 
"User Cell" is any cell that has a PTI that is 0,1, 2 or 3. 
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function CellRxed() 

WhichPMG <= CID.PMG; 
if (WhichPMG o 0) then 

if (PMGT(WhichPMG).Enabled = TRUE) then 

— check for cell being a User Cell 

if ((PMGT(WhichPMG).F4 Level = TRUE) and -- is a VPC 
((Cell. VCI in ( 1 , 2, 5)) or (Cell. VCI >= 1 6))) or 
((PMGT( WhichPMG. F4 Level = FALSE) and -- is a VCC 
(Cell.PTI in (0, 1, 2, 3))) then 

— check for late FMC 

if (PMGT(WhichPMG).BlockCounr=1.5*BIockSize) then 
GeneratePMGOverflowError() ; 

end if; 

— increment counts 
(PMGT(WhichPMG).BlockCount <= 

(PMGT(WhichPMG).BlockCount + 1 ; 
PMGT(WhichPMG).BlockSizeCount <= 

PMGT(WhichPMG).BlockReqCount + 1 ; 
PMGT(WhichPMG).TUC <= PMGT( WhichPMG) .TUC + 1 ; 
if(Cell.CLP = 0)then 

PMGT(WhichPMG).TUCO; <= 

PMGT(WhichPMG).TUCO; + 1; 

end if; 

PMGT(WhichPMG).BEDC <= NewBEDC(Cell.Payload, 
PMGT(WhichPMG).BEDG); 

end if; 

— request next FMC 

if PMGT(WhichPMG).BlockReqCount = 

PMGT(WhichPMG).Blocksize) then 
PMGT(WhichPMG).BIockReqCount <= 0; 
SendFMCRequest(PMGT(WhichPMG).CID); 
end if; 

end if; 

end if; 

end CellRxed; 

Table 12. Example Pseudo-Code of Function for Determining if 

a Cell is "User Cell" 
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CPU Controller 

FIG. 9 shows the functional architecture of the Forte 
ASIC 104 surrounding the CPU Controller block 404, in 
accordance with one embodiment of the present invention. The 
5 CPU Controller 404 enables the CPU to insert cells into the 
egress cell flow. To do this the CPU must write the entire 
cell into the Forte 104. Once the CPU has written the entire 
cell into the Forte 104, the CPU can then request the 
insertion of the cell by writing the CID of the cell into the 
10 Insert Request Register. Once this is done, the CPU 

__INSERTION_BUSY flag will be set to indicate to the CPU that 
the cell has not been sent yet. The Cell Inserter will 
request the insertion at the next possible time. 

When the cell slot reaches the Forte 104, the CPU's cell 
15 will be inserted and written into the Egress Cell Buffer ready 
for transmission to the LIM or SAR. Once the cell has been 
queued for transmission, the CPU INSERTION BUSY flag will be 
cleared, and the CPU Cell Sent interrupt will be generated, so 
that the CPU can proceed with the next request. 

20 At the time that the initial request is sent to the FSS 

102, the CPU Timeout counter starts to decrement once per MTS . 
If the counter reaches zero, a CPU Timeout Interrupt will be 
sent to the CPU. This basically means that the insertion 
request has been lost. However, it is possible that the 

25 initial insertion request has just been seriously delayed and 
may eventually arrive at the Forte 104. The Forte 104 will 
discard any cells that are tagged with a CellType of CPU if 
they do not match the appropriate CID. 

There is no interrupt to indicate that there was a 
30 mismatch of CIDs as the CPU Timeout will have indicated that 
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an insertion error has occurred. The CPU Timeout initial 
value can be configured by the CPU . If it is set to zero then 
the timer will be disabled. 

Back Pressure Controller 

5 FIG. 10 shows the functional architecture of the Forte 

ASIC 104 surrounding the Back Pressure Controller block 408, 
in accordance with one embodiment of the present invention. 
The Back Pressure Controller (BPC) receives back pressure 
state information from the LIM interface circuitry 322. 

10 The BPC then applies that back pressure directly to the 

Egress Output Controller in the LIM Transmitter 410. Back 
pressure is also applied to the SSS 108, on a dedicated 
SIFwire channel, so that it will stop sending cells on certain 
ports . 

15 If the LIM 312 indicates that a particular port is 

blocked, then the Forte 104 will stop sending cells to the LIM 
312. Back pressure to the SSS 108 will only be applied when 
the number of cells stored in the Egress Cell Buffer is 
greater then or equal to half of the ports allocated buffer 

20 space. The back pressure is removed when the cells stored 
decreases below half. 

For example, a 622Mbps port is allocated buffer space for 
16 cells. If the LIM Interface 322 applies back pressure on 
this port, the Forte 104 will apply back pressure to the SSS 
25 108 when the number of full cells has reached 8, and will 

remove back pressure when the number of cells stored decreases 
below 8 . 

Back pressure from the LIM 322 is not applied directly to 
the SSS 108 in order to ensure that the LIM ports 312 do not 
30 get starved of traffic. 
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The CPU can also apply back pressure to the SSS 108 by 
writing to the CPU_BackPressure register. This back pressure 
will be combined with the back pressure from the Egress Cell 
Buffer before being sent to the SSS 108. 

The backpressure information from the LIM 322 is 
protected by odd parity to ensure that the information is 
received correctly. If the parity is found to be incorrect 
then the information received is discarded, and the CPU is 
informed of the error. 

SIFwire Controller 

FIG. 11 shows the functional architecture of the Forte 
ASIC 104 surrounding the SIFwire Controller 406, in accordance 
with one embodiment of the present invention. The SIFwire 
controller 406 controls which part of the Forte 104 has access 
to each of the four SIFwire channels on the Forte 104. Table 
13 below shows the controller of each SIFwire channel. 



SIFwire 
Channel 


Controlled by 


Connected to 


0 


CPU&ABRDC 


SSS 


1 


Forte Back Pressure 


SSS back Pressure 


2 


CPU & ABRDC 


FSS 


3 


Forte Insertion Requester 


FSS Insertion Requester 



Table 13. Examples of Controllers for each SIFwire Channel 

SIFwires 0 and 2 can be accessed by both the CPU and the 
ABR DC. In the event of contention, the ABR DC is given 
priority. In the event of continued contention a configurable 
maximum of consecutive accesses is granted to the ABR DC then 
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one access is provided for the CPU. The number of ABR DC 
accesses is controlled by the SIFwire control register. 

The ABR DC and CPU will see separate banks of control 
registers for the SIFwire interface. A single bit flag in the 
5 serial frame format is used to identify the source of commands 
and the destination of the responses. 

The Filter Subsystem 102 keeps per-port ABR counts for 
one QID that are generally collected by the ABR DC over the 
SIFwire interface. However, when a count exceeds some 
10 threshold, the FSS 102 will generate an unsolicited SIFwire 
response to transfer the PortID and ABR QID count. 

The ABR DC interface expects this data on SIFwire 2 and 
will store the information in an array of registers. It will 
then interrupt the ABR DC to say that the information has 
15 arrived and set a bit, in the ABR-QID. PORT register to 
indicate which count has been updated. 

This unsolicited ABR QID count facility is only available 
for SIFwire 2 . 

The other two SIFwire channels (channels 1 and 3) are 
20 completely controlled by the Forte 104. Channel 1 is used to 
supply back pressure information to the SSS 108, and channel 3 
is used for requesting cell insertions from the FSS 102. 

System And Method Implementation ' 

Portions of the present invention may be conveniently 
25 implemented using a conventional general purpose or a 

specialized digital computer or microprocessor programmed 
according to the teachings of the present disclosure, as will 
be apparent to those skilled in the computer art. 
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Appropriate software coding can readily be prepared by- 
skilled programmers based on the teachings of the present 
disclosure, as will be apparent to those skilled in the 
software art. The invention may also be implemented by the 
preparation of application specific integrated circuits or by 
interconnecting an appropriate network of conventional 
component circuits, as will be readily apparent to those 
skilled in the art. 

The present invention includes a computer program product 
which is a storage medium (media) having instructions stored 
thereon/in which can be used to control, or cause, a computer 
to perform any of the processes of the present invention. The 
storage medium can include, but is not limited to, any type of 
disk including floppy disks, mini disks (MD's), optical discs, 
DVD, CD-ROMS, micro-drive, and magneto-optical disks, ROMs, 
RAMS, EPROMs, EEPROMs , DRAMS, VRAMs , flash memory devices 
(including flash cards) , magnetic pr optical cards, 
nanosystems (including molecular memory ICs) , RAID devices, 
remote data storage/archive/warehousing, or any type of media 
or device suitable for storing instructions and/or data. 

Stored on any one of the computer readable medium 
(media) ., the present invention includes software for 
controlling both the hardware of the general 
purpose/specialized computer or microprocessor, and for 
enabling the computer or microprocessor to interact with a 
human user or other mechanism utilizing the results of the 
preset invention. Such software may include, but is not 
limited to, device drivers, operating systems, and user 
applications. Ultimately, such computer readable media 
further includes software for performing the present 
invention, as described above. 
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Included in the programming (software) of the 
general/specialized computer or microprocessor are software 
modules for implementing the teachings of the present 
invention, including, but not limited to, receiving an 
5 insertion request for an empty memory cell to be inserted into 
the data flow, receiving a base connection identification 
(CID) associated with the insertion request, determining an 
appropriate insertion scheme for carrying out the insertion 
request, and sending the insertion request to an insertion 
10 device configured to insert the empty memory cell- into a main 
buffer for the data flow, according to processes of the 
present invention. 

In the foregoing specification, the invention has been 
described with reference to specific embodiments thereof. It 
15 will, however, be evident that various modifications and 

changes may be made thereto without departing from the broader 
spirit and scope of the invention. The specification and 
drawings are, accordingly, to be regarded in an illustrative 
rather than a restrictive sense. 



Attorney Docket No. 10327- 003600US 



37 



PA 3240608 vl 



